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(57) Abstract 

Techniques for improving the resolution of images (either 
analog images, analytic images, or images having a higher 
resolution than that of a display device) to be rendered on 
patterned displays. In one aspect of the present invention, 
discrete values of a color scan line such as the color scan 
line (1510) for the color red consist of N samples per emitter 
(for example, two or more samples (1515r), per emitter). 
Hie samples (1515r) are filtered (e.g. averaged) in order to 
generate an oversampled color scan line (1520r) (such as a 
three times oversampled color scan line ). The new samples of 
the oversampled color scan line (1520r) are filtered again with 
box filters (1525) to generate color values (1530) associated 
with sub-pixel components. The filters (1525) are centered 
at locations that correspond to the centers of the sub-^)ixel 
elements. Thus, the filters (1525) are offset, and consequently 
operate at distinct positions within the image for each of the 
color components. Once all of the colors are processed, filter 
output may be gamma corrrect (1540) based on the gamma 
response of a display on which the image is to be rendered. 
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METHODS, APPARATUS AND DATA STRUCTURES 
FOR ENHANCING THE RESOLUTION OF IMAGES 
TO BE RENDERED ON PATTERNED DISPLAY DEVICES 

§1.1 FIELD OF THE INVENTION 

The present invention concerns techniques for enhancing the resolution of 
images, such as fonts, line drawings, or black-and-white or full-color images for 
example, to be rendered on a patterned output device, such as a flat panel video 
monitor or an LCD video monitor for example. 

§1.2 RELATED ART 

The present invention may be used in the context of patterned output devices 
such as flat panel video monitors, or LCD video monitors for example. In particular, 
the present invention may be used as a part of processing to produce higher resolution 
images, such as more legible text for example, on LCD video monitors. Although the 
structure and operation of display devices in general, and flat panel display devices, 
such as LCD monitors for example, in particular, are known by those skilled in the art, 
they are discussed in § 1.2.1 below for the reader's convenience. Then, known ways 
of rendering text, line art and graphics on such displays are discussed in §§ 1.2.2, 1.2.3 
and 1.2.4 below. 

§1.2.1 DISPLAY DEVICES 

Color display devices have become the principal display devices of choice for 
most computer users. Color is typically displayed on a monitor by operating the 
display device to emit light (such as a combination of red, green, and blue light for 
example) which results in one or more colors being perceived by the human eye. 

Although color video monitors in general, and LCD video monitors in 
particular, are known to those skilled in the art, they are introduced below for the 
reader's convenience. In § 1.2.1.1 below, cathode ray tube (or CRT) video monitors 
are first introduced. Then, in § 1 .2. 1 .2 below, LCD video monitors are introduced. 

§1.2.1.1 CRT VIDEO MONITORS 

Cathode ray tube (CRT) display devices include phosphor coatings which may 
be applied as dots in a sequence on the screen of the CRT. A different phosphor 
coating is normally associated with the generation of different colors, such as red, 
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green, and blue for example. Consequently, repeated sequences of phosphor dots are 
defined on the screen of the video monitor. When a phosphor dot is excited by a beam 
of electrons, it will generate its associated color, such as red, green and blue for 
example. 

5 The term "pixel" is commonly used to refer to one spot in a group of spots, 

such as rectangular grid of thousands of such spots for example. The spots are 
selectively activated to form an image on the display device. In most color CRTs, a 
single triad of red, green and blue phosphor dots cannot be uniquely selected. 
Consequently, the smallest possible pixel size will depend on the focus, alignment and 
10 bandwidth of the electron guns used to excite the phosphor dots. The light emitted 
from one or more triads of red, green and blue phosphor dots, in various arrangements 
known for CRT displays, tend to blend together giving, at a distance, the appearance 
of a single colored light source. 

In color displays, the intensity of the light emitted from the additive primary 
1 5 colors (such as red, green, and blue) can be varied to achieve the appearance of almost 
any desired color pixel. Adding no color, i.e., emitting no light, produces a black pixel 
Adding 100 percent of all three (3) colors produces a white pixel. 

Having introduced color CRT video monitors, color LCD video monitors are 
now introduced in § 1.2.1.2 below. 
20 §1.2.1.2 LCD VIDEO MONITORS 

Portable computing devices (also referred to generally as computing appliances 
or untethered computing appliances) often use liquid crystal displays (LCDs) or other 
flat panel display devices, instead of CRT displays. This is because flat panel displays 
tend to be smaller and lighter than CRT displays. In addition, flat panel displays are 
25 well suited for battery powered applications since they typically consume less power 
than comparably sized CRT displays. Further, LCD flat panel monitors are even 
becoming more popular in the desktop computing environment. 

Color LCD displays are examples of display devices which distinctly address 
elements (referred to herein as pixel sub-components, pixel sub-elements, or simply, 
30 emitters) to represent each pixel of an image being displayed. Normally, each pixel 
element of a color LCD display includes three (3) non-square elements. More 
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specifically, each pixel element may include adjacent red, green and blue (RGB) pixel 
sub-components. Thus, a set of RGB pixel sub-components together define a single 
pixel element. 

Known LCD displays generally include a series of RGB pixel sub-components 
which are commonly arranged to form stripes along the display. The RGB stripes 
normally run the entire length of the display in one direction. The resulting RGB 
stripes are sometimes referred to as "RGB striping" Common LCD monitors used for 
computer applications, which are wider than they are tall, tend to have RGB vertical 
stripes. Naturally, however, some LCD monitors may have RGB horizontal stripes. 

Figure 1 illustrates a known LCD screen 100 comprising pixels arranged in a 
plurality of rows (R1-R12) and columns (C1-C16). That is, a pixel is defined at each 
row-column intersection. Each pixel includes a red pixel sub-component, depicted 
with moderate stippling, a green component, depicted with dense stippling, and a blue 
component, depicted with sparse stippling. Figure 2 illustrates the upper left hand 
portion of the known display 100 in greater detail. Note how each pixel element, such 
as, the (R2, C4) pixel element for example, comprises three (3) distinct sub-element or 
sub-components; a red sub-component 206, a green sub-component 207 and a blue 
sub-component 208. In the exemplary display illustrated, each known pixel sub- 
component 206, 207, 208 is 1/3, or approximately 1/3, the width of a pixel while being 
equal, or approximately equal, in height to the height of a pixel. Thus, when 
combined, the three 1/3 width, full height, pixel sub-components 206, 207, 208 define 
a single pixel element. 

As illustrated in Figure 1, one known arrangement of RGB pixel sub- 
components 206, 207, 208 form what appear to be vertical color stripes on the display 
100. 

Accordingly, the arrangement of 1/3 width color sub-components 206, 207. 
208, in the known manner illustrated in Figures 1 and 2, exhibit what is sometimes 
called "vertical griping". 

In known systems, the RGB pixel sub-components are generally used as a 
group to generate a single colored pixel corresponding to a single sample of the image 
to be represented. More specifically, in known systems, luminous intensity values for 
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all the pixel sub-components of a pixel element are generated from a single sample of 
the image to be rendered. 

Having introduced the general structure and operation of known LCD displays, 
known techniques for rendering text on such LCD displays, as well as perceived 
5 shortcomings of such known techniques, are introduced in § 1.2.2 below. Then, 
known techniques for rendering line art or images on such LCD displays, as well as 
perceived shortcomings of such known techniques, are introduced in § 1.2.3 below. 
Finally, rendering graphics is introduced in § 1.2.4 below. 
§1.2-2 RENDERING TEXT ON DISPLAYS 
10 The expression of textual information using font sets is introduced in § 1.2.2.1 

below. Then, the rendering of textual information using so-called pixel precision and 
perceived shortcomings of doing so are introduced in § 1.2.2.2 below. 
§1.2.2.1 FONT SETS 

A "font" is a set of characters of the same typeface (such as Times Roman, 
15 Courier New, etc.), the same style (such as italic), the same weight (such as bold and, 
strictly speaking, the same size). Characters may include symbols, such as the "Parties 
MT", "Webdings", and "Wingdings" symbol groups found on the Word™ word 
processor from Microsoft Corporation of Redmond, Washington for example. A 
"typeface" is a specific named design of a set of printed characters (e.g. Helvetica Bold 
20 Oblique), that has a specified obliqueness (i.e. ? degree of slant) and stoke weight (i.e., 
line thickness). Strictly speaking, a typeface is not the same as a font, which is a 
specific size of a specific typeface (such as 12-point Helvetica Bold Oblique). 
However, since some fonts are "scalable", the terms "font" and "typeface" may 
sometimes be used interchangeably. A "typeface family" is a group of related 
25 typefaces. For example, the Helvetica family may include Helvetica, Helvetica Bold, 
Helvetica Oblique and Helvetica Bold Oblique. 

Many modern computer systems use font outline technology, such as scalable 
fonts for example, to facilitate the rendering and display of text. TrueType™ fonts 
from Microsoft Corporation of Redmond, Washington are an example of such 
30 technology. In such systems, various font sets, such as "Times Mew Roman," "Onyx," 
"Courier New," etc. for example, may be provided. The font set normally includes an 
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analytic outline representation, such as a series of contours for example, for each 
character which may be displayed using the provided font set. The contours may be 
straight lines or curves for example. Curves may be denned by a series of points that 
describe second order Bezier-splines for example. The points defining a curve are 
typically numbered in consecutive order. The ordering of the points may be important. 
For example, the character outline may be "filled" to the right of curves when the 
curves are followed in the direction of increasing point numbers. Thus the analytic 
character outline representation may be defined by a set of points and mathematical 
formulas. 

The point locations may be described in "font units" for example. A "font unit" 
may be defined as the smallest measurable unit in an "em" square, which is an 
imaginary square that is used to size and align glyphs (a "glyph" can be thought of as a 
character). Figure 3 illustrates an "em" square 310 around a character outline 320 of 
the letter Q. Historically, an "em" was approximately equal to the width of a capital 
M. Further, historically, glyphs could not extend beyond the em square. More 
generally, however, the dimensions of an "em" square are those of the full body height 
340 of a font plus some extra spacing. This extra spacing was provided to prevent 
lines of text from colliding when typeset without extra leading was used. Further, in 
general, portions of glyphs can extend outside of the em square. The coordinates of 
the points defining the lines and curves (or contours) may be positioned relative to a 
baseline 330 (Y coordinate = 0). The portion of the character outline 320 above the 
baseline 330 is referred to as the "ascent" 342 of the glyph. The portion of the 
character outline 320 below the baseline 330 is referred to as the "decent" 344 of the 
glyph. Note that in some languages, such as Japanese for example, the characters sit 
on the baseline, with no portion of the character extending below the baseline. 

The stored outline character representation normally does not represent space 
beyond the maximum horizontal and vertical boundaries of the character (also referred 
to as "white space" or "side bearings"). Therefore, the stored character outline portion 
of a character font is often referred to as a black body (or BB). A font generator is a 
program for transforming character outlines into bitmaps of the style and size required 
by an application. Font generators (also referred to as "rasteiizers") typically operate 
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by scaling a character outline to a requested size and can often expand or compress the 
characters that they generate- 
In addition to stored black body character outline information, a character font 
normally includes black body size, black body positioning, and overall character width 
5 information. Black body size information is sometimes expressed in terms of the 
dimensions of a bounding box used to define the vertical and horizontal borders of the 
black body. 

Certain terms used to define a character are now defined with reference to 
Figure 4, which illustrates character outlines of the letters A and I 400. Box 408 is a 

1 0 bounding box which defines the size of the black body 407 of the character (A). The 
total width of the character (A), including white space to be associated with the 
character (A), is denoted by an advance width (or AW) value 402. The advance width 
typically starts to a point left of the bounding box 408. This point 404 is referred to as 
the left side bearing point (or LSBP). The left side bearing point 404 defines the 

1 5 horizontal starting point for positioning the character (A) relative to a current display 
position. The horizontal distance 410 between the left end of the bounding box 408 
and the left side bearing point 404 is referred to as the left side bearing (or LSB). The 
left side bearing 410 indicates the amount of white space to be placed between the left 
end of the bounding box 408 of a current character (A) and the right side bearing point 

20 of the preceding character (not shown). The point 406 to the right of the bounding 
box 408 at the end of the advance width 402 is referred to as the right side bearing 
point (or RSBP). The right side bearing point 406 defines the end of the current 
character (A) and the point at which the left side bearing point 404 of the next 
character (I) should be positioned. The horizontal distance 412 between the right end 

25 of the bounding box 408 and the right side bearing point 406 is referred to as the right 
side bearing (or RSB). The right side bearing 412 indicates the amount of white space 
to be placed between the right end of the bounding box 408 of a current character (A) 
and the left side bearing point 404' of the next character (I). Note that the left and 
right side bearings may have zero (0) or negative values. Note also that in characters 

30 used in Japanese and other Far Eastern languages, metrics analogous to advance width, 
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left side bearing and right side bearing - namely, advance height (AH), top side 
bearing (TSB) and bottom side bearing (BSB) ~ may be used. 

As discussed above, a scalable font file normally includes black body size, black 
body positioning, and overall character width information for each supported 
5 character. The black body size information may include horizontal and vertical size 
information expressed in the form of bounding box 408 dimensions. The black body 
positioning information may expressed as a left side bearing value 410. Overall 
character width information may be expressed as an advance width 402. 

§1.2.2.2 RENDERING TEXT TO PIXEL PRECISION 
1 0 1° the following, known techniques for rendering text on an output device such 

as a display (or printer) is described in § 1.2.2.2.1. Then, an example illustrating 
round-off errors which may occur when using such known techniques is described in § 
1.2.2.2.2. 

§1.2.2.2.1 TECHNIQUE FOR RENDERING TEXT 

1 5 Figure 5 is a high level diagram of processes that may be performed when an 

application requests that text be rendered on a display device. Basically, as will be 
described in more detail below, text may be rendered by: (i) loading a font and 
supplying it to a rasterizer; (ii) scaling the font outline based on the point size and the 
resolution of the display device; (iii) applying hints to the outline; (iv) filling the grid 

20 fitted outline with pixels to generate a raster bitmap; (v) scanning for dropouts 
(optional); (yi) caching the raster bitmap; and (vii) transferring the raster bitmap to the 
display device. 

In the case of scaling fonts, the font unit coordinates used to define the position 
of points defining contours of a character outline are scaled to device specific pixel 

25 coordinates. That is, when the resolution of the em square is used to define a character 
outline, before that character can be displayed, it must be scaled to reflect the size, 
transformation and the characteristics of the output device on which it is to be 
rendered. The scaled outline describes the character outline in units that reflect the 
absolute unit of measurement used to measure pixels of the output device, rather than 

30 the relative system of measurement of font units per em. 
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Specifically, with known techniques, values in the em square are converted to values in 

the pixel coordinate system in accordance with the following formula: 

size in pixels = (1) 

5 character outline size • point size ■ output device resolution 

72 points per inch number of font units per em 
where the character outline size is in font units, and output device resolution is 
in pixels/inch. 

1 0 The resolution of the output device may be specified by the number of dots or pixels 
per inch (dpi). For example, a VGA video monitor may be treated as a 96 dpi device, 
a laser printer may be treated as a 300 dpi device, an EGA video monitor may be 
treated as a 96 dpi device in the horizontal (X) direction, but a 72 dpi device in the 
vertical (Y) direction. The font units per em may (but need not) be chosen to be a 

1 5 power of two (2), such as 2048 (=2 11 ) for example. 

Figure 5 is a high level diagram of processes which may be performed by a 
known text rendering system. As shown in Figure 5, an application process 510, such 
as a word processor or contact manager for example, may request that text be 
displayed and may specify a point size for the text. Although not shown in Figure 5, 

20 the application process 510 may also request a font name, background and foreground 
colors and a screen location at which the text is to be rendered. The text and, if 
applicable, the point size, 512 are provided to a graphics display interface (or GDI) 
process (or more generally, a graphics display interface) 522. The GDI process 522 
uses display information 524 (which may include such display resolution information as 

25 pixels per inch on the display) and character information 525 (which may be a 
character outline information which may be represented as points defining a sequence 
of contours such as lines and curves, advance width information and left side bearing 
information) to generate glyphs (or to access cached glyphs which have already been 
generated). Glyphs may include a bitmap of a scaled character outline (or a bounding 

30 box 308 containing black body 307 information), advance width 302 information, and 
left side bearing 310 information. Each of the bits of the bitmap may have associated 
red, green and blue luminous intensity values. The graphics display interface process 
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522 is described in more detail in § 1.2.2.2.1.1 below. The graphics display interface 
process 522, the display information 524, and the glyph cache 526 may be a part of, 
and effected by, an operating system, such as the Windows® CE or Windows NT® 
operating systems (from Microsoft Corporation of Redmond, Washington) for 
example. 

Glyphs (also referred to as digital font representations) 528' or 528, either from 
the glyph cache 526 or from the graphics display interface process 522 are then 
provided to a display driver management process (or more generally, a display driver 
manager) 535. The display driver management process 535 may be a part of a display 
(or video) driver 530. Typically, a display driver 530 may be software which permits 
a computer operating system to communicate with a particular video display 
Basically, the display driver management process 535 may invoke a color palette 
selection process 538. These processes 535 and 538 serve to convert the character 
glyph information into the actual pixel intensity values. The display driver management 
process 535 receives, as input, glyphs and display information 524'. The display 
information 524' may include, for example, foreground/background color information 
color palette information and pixel value format information. 

The processed pixel values may then be forwarded as video frame part(s) 540 
along with screen (and perhaps window) positioning information (e.g. from the 
application process 510 and/or operating system), to a display (video) adapter 550 A 
display adapter 550 may include electronic components that generate a video signal 
sent to the display 560. A frame buffer process 552 may be used to store the received 
video frame part(s) in a screen frame buffer 554 of the display adapter 550. Using the 
screen frame buffer 554 allows a single image of, e.g., a text string, to be generated 
from glyphs representing several different characters. The video frame(s) from the 
screen frame buffer 554 is then provided to a display adaptation process 553 which 
adapts the video for a particular display device. The display adaptation process 558 
may also be effected by the display adapter 550. 

Finally, the adapted video is presented to the display device 560, such as an 
LCD display for example, for rendering. 



WO 00/42762 



PCT/USOO/00804 



10 

. Having provided an overview of a text rendering system, the graphics display 
interface process 522 is now described in more detail in § 1.2.2.2.1.1 below. The 
processes which may be performed by the display driver are then described in more 
detail in § 1.2.2.2.1.2 below. 
5 §1.2.2.2.1.1 GRAPHICS DISPLAY INTERFACE 

Figure 6 illustrates processes that may be performed by a graphics display 
interface (or GDI) process 522, as well as data that may be used by the GDI process 
522. As shown in Figure 6, the GDI process 522 may include a glyph cache 
management process (or more generally, a glyph cache manager) 610 which accepts 
10 text, or more specifically, requests to display text, 512. The request may include the 
point size of the text. The glyph cache management process 610 forwards this request 
to the glyph cache 526. If the glyph cache 526 includes the glyph corresponding to the 
requested text character, it provides it for downstream processing. If, on the other 
hand, the glyph cache 526 does not have the glyph corresponding to the requested text 
15 character, it so informs the glyph cache management process 610 which, in turn, 
submits a request to generate the needed glyph to the type rasterization process (or 
more generally, a type rasterizer) 620. Basically, a type rasterization process 620 may 
be effected by hardware and/or software and converts a character outline (which may, 
recall, include points which define contours such as lines and curves based on 
20 mathematical formulas) into a raster (that is, a bitmapped) image. Each pixel of the 
bitmap image may have a color value and a brightness for example. A type 
rasterization process is described in § 1.2.2.2.1.1.1 below. 
§1.2.2.2.1.1.1 RASTERIZER 

To reiterate, the type rasterization process 620 basically transforms character 
25 outlines into bitmapped images. The scale of the bitmap may be based on the point 
size of the font and the resolution (e.g., pixels per inch) of the display device 560. The 
text, font, and r;oint size information may be obtained from the application 510, while 
the resolution of the display device 560 may be obtained from a system configuration 
or display driver file or from monitor settings stored in memory by the operating 
30 system. The display information 524 may also include foreground/background color 
information, gamma values, palette information and/or display adapter/display device 
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pixel value format information. To reiterate, this information may be provided from 
the graphics display interface 522 in response to a request from the application process 
510. If, however, the background of the text requested is to be transparent (as 
opposed to Opaque), the background color information is what is being rendered on 
the display (such as a bitmap image or other text for example) and is provided from the 
display device 560 or the video frame buffer 554. 

Basically, the rasterization process may include two (2) or three (3) sub-steps 
or sub-processes. First, the character outline is scaled using a scaling process 622. 
This process is described below. Next, the scaled image generated by the scaling 
process 622 may be placed on a grid and have portions extended or shrunk using a 
hinting process 626. This process is also described below. Then, an outline fill 
process 628 is used to fill the grid-fitted outline to generate a raster bitmap. This 
process is also described below. 

When scaling fonts in conventional systems such as TrueType™ from 
Microsoft Corporation of Redmond, Washington, the font unit coordinates used to 
define the position of points defining contours of a character outline were scaled to 
device specific pixel coordinates. That is, since the resolution of the em square was 
used to define a character outline, before that character could be displayed, it was 
scaled to reflect the size, transformation and the characteristics of the output device on 
which it was to be rendered. Recall that the scaled outline describes the character 
outline in units that reflect the absolute unit of measurement used to measure pixels of 
the output device, rather than the relative system of measurement of font units per em. 
Thus, recall that values in the em square were converted to values in the pixel 
coordinate system in accordance with the following formula: 

size in pixels = ^ 

character outline size • point size • output device resolution 

72 points per inch number of font units per em ~ 
where the character outline size is in font units, and output device resolution is 
in pixels/inch. 

Recall that the resolution of an output device may be specified by the number of dots 
or pixels per inch (dpi). 
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The purpose of hinting (also referred to as "instructing a glyph") is to ensure 
that critical characteristics of the original font design are preserved when the glyph is 
rendered at different sizes and on different devices. Consistent stem weights, 
consistent "color" (that is, in this context, the balance of black and white on a page or 
5 screen), even spacing, and avoiding pixel dropout are common goals of hinting. In the 
past, uninstructed, or unhinted, fonts would generally produce good quality results at 
sufficiently high resolutions and point sizes. However, for many fonts, legibility may 
become compromised at smaller point sizes on lower resolution displays. For example, 
at low resolutions, with few pixels available to describe the character shapes, features 

10 such as stem weights, crossbar widths and serif details can become irregular, or 
inconsistent, or even missed completely. 

Basically, hinting may involve "grid placement" and "grid fitting". Grid 
placement is used to align a scaled character within a grid, that is used by a subsequent 
outline fill process 628, in a manner intended to optimize the accurate display of the 

15 character using the available sub-pixel elements. Grid fitting involves distorting 
character outlines so that the character better conforms to the shape of the grid. Grid 
fitting ensures that certain features of the glyphs are regularized. Since the outlines are 
only distorted at a specified number of smaller sizes, the contours of the fonts at high 
resolutions remain unchanged and undistorted. 

20 In grid placement, sub-pixel element boundaries may be treated as boundaries 

along which characters can, and should, be aligned or boundaries to which the outline 
of a character snould be adjusted. 

Other known hinting instructions may also be carried out on the scaled 
character outline. 

25 In an implementation of anti-aliased text for TrueType™ fonts supported in 

Windows NT™ 4. the hinted image 627 is overscaled four (4) times in both the X and 
Y directions. The image is then sampled, i.e. for every physical pixel, which is 
represented by 4-by-4 portion of the grid in an overscaled image, the blend factor alpha 
is computed for that pixel by simply counting the squares having centers which lie 

30 within the glyph outline and dividing the result by 16. As a result, the 
foreground/background blend factor alpha is expressed as k/16 and is computed for 
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every pixel. This whole process is also called standard anti-aliasing filtering. 
Unfortunately, however, such standard anti-aliasing tends to blur the image. Similar 
implementation exists in Windows 95 and Windows 98, and the only difference is that 
the image is overscaled two (2) times in both X and Y, so that alpha for every pixel is 
expressed as k/4, where k is a number of squares within the glyph outline. 

The outline fill process 628 basically determines whether the center of each 
pixel is enclosed within the character outline. If the center of a pixel is enclosed within 
the character outline, that pixel is turned ON. Otherwise, the pixel is left OFF. The 
problem of "pixel dropout" may occur whenever a connected region of a glyph interior 
contains two ON pixels that cannot be connected by a straight line that passes through 
only those ON pixels. Pixel dropout may be overcome by looking at an imaginary line 
segment connected two adjacent pixel centers, determining whether the line segment is 
intersected by both an on-transition contour and off-transition contour, determining 
whether the two contour lines continue in both directions to cut other line segments 
between adjacent pixel centers and, if so, turning pixels ON. 

The rasterized glyphs are then cached in glyph cache 526. Caching glyphs is 
useful. More specifically, since most Latin fonts have only about 200 characters, a 
reasonably sized cache makes the speed of the rasterizer almost meaningless. This is 
because the rasterizeer runs once, for example when a new font or point size is 
selected. Then, the bitmaps are transferred out of the glyph cache 526 as needed. 

The scaling process 622 of the known system just described may introduce 
certain rounding errors. Constraints are enforced by (i) scaling the size and positioning 
information included in a character font as a function of the point size and device 
resolution as just described above, and (ii) then rounding the size and positioning 
values to integer multiples of the pixel size used in the particular display device. Using 
pixel size units as the minimum (or "atomic") distance unit produces what is called 
"pixel precision"; since the values are accurate to the size of one (1) pixel. 

Rounding size and positioning values of character fonts to pixel precision 
introduces changes, or errors, into displayed images. Each of these errors may be up 
to 1/2 a pixel in size (assuming that values less than 1/2 a pixel are rounded down and 
values greater than or equal to 1/2 a pixel are rounded up). Thus, the overall width of 
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a character may be less precise than desired since the character's AW is (may be) 
rounded In addition, the positioning of a character's black body within the total 
horizontal space allocated to that character may be sub-optimal since the left side 
bearing is (may be) rounded. At small point sizes, the changes introduced by rounding 
5 using pixel precision can be significant. 

§ 1.2.3 RENDERING LINE DRAWINGS 

As was the case when scaling character outlines, when rendering line drawings, 
the boundaries between the (black) line portions and the (white) background are 
typically forced to correspond to pixel boundaries. This may be done by rounding the 

1 0 position values of the (black) line portions to integer multiples of the pixel size used in 
the particular display device. Referring to Figure 7, this may be done by a scaling 
process 710 which accepts analytic image information 702 and generates pixel 
resolution digital image information 728. To reiterate, using pixel size units as the 
minimum (or "atomic") positioning unit produces what is called "pixel precision" since 

1 5 the position values are accurate to the size of one (1) pixel. 

Rounding position values for line drawings to pixel precision introduces 
changes, or errors, into displayed images. Each of these errors may be up to 1/2 a 
pixel in size (assuming that values less than 1/2 a pixel are rounded down and values 
greater than or equal to 1/2 a pixel are rounded up). Thus, the overall width of a line 

20 section may be less precise than desired since the width or weight of the line is (may 
be) rounded. 

§ 1.2.4 RENDERING GRAPHICS 

Similar to text and line drawings, certain graphics, represented analytically or 
by a resolution higher than that of a display device 650, may have to be scaled and 
25 rounded to correspond to the resolution of the display device 650. Referring to Figure 
7, this may be done by a scaling process 710 which accepts ultra resolution digital 
image information 704 and generates pixel resolution digital image information. Thus, 
rounding errors can be introduced here as well. 
§ 1.2.5 UNMET NEEDS 
30 In view of the errors introduced when rounding character values, line drawings, 

or high resolution or analytic graphics to pixel precision as introduced above, methods 
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and apparatus to improve character spacing and positioning, to increase the legibility 
and perceived quality of text, to improve the resolution of line drawings, and/or to 
improve the resolution of images are needed. Such methods and apparatus should not 
blur the image, as occurs when standard anti-aliasing is used. 
5 §2. SUMMARY OF THE INVENTION 

The present invention improves the resolution of images (either analog images, 
analytic images, or images having a higher resolution than that of a display device) to 
be rendered on patterned displays In one aspect of the present invention, an 
overscaling or oversampling process may accept analytic character information, such 
1 0 as contours for example, and a scale factor or grid and overscale or oversample the 
analytic character information to produce an overscaled or oversampled image. The 
overscaled or oversampled image generated has a higher resolution than the display 
upon which the character is to be rendered. If, for example, the display is a RGB 
striped LCD monitor, the ultra-resolution image may have a resolution corresponding 
15 to the sub-pixel component resolution of the display, or an integer multiple thereof. 
For example, if a vertically striped RGB LCD monitor is to be used, the ultra- 
resolution image 704 may have a pixel resolution in the Y direction and a 1/3 (or 1/3N, 
where N is an integer) pixel resolution in the X direction. If, on the other hand, a 
horizontally striped RGB LCD monitor is to be used, the ultra-resolution image may 
20 have a pixel resolution in the X direction and a 1/3 (or 1/3N) pixel resolution in the Y 
direction. Then a process for combining displaced samples of the ultra-resolution 
image 624' may be used to generate another ultra-resolution image (or an image with 
sub-pixel information) which is then cached. The cached character information may 
then be accessed by a compositing process which uses foreground and background 
25 color information. 

An analytic image, such as a line drawing for example, may be applied to the 
oversampling/overscaling process as was the case with the character analytic image. 
However, since the analytic image may have different units than that of the character 
analytic image, the scale factor applied may be different. In any event, the downstream 
30 processes may be similarly applied. 
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Since an ultra resolution image is already "digitized", that is, not merely 
mathematically expressed contours or lines between points, it may be applied directly 
to a process for combining displaced samples of the ultra-resolution image to generate 
another ultra-resolution image (or an image with sub-pixel information). Downstream 
processing may then be similarly applied. 

In one embodiment of the present invention, functionality of the 
overscaling/oversampling process the processes for combining displaced samples may 
be combined into a single step analytic to digital sub-pixel resolution conversion 
process. 

§ 3. BRIEF DESCRIPTION OF THE DRAWINGS 

Figures 1 and 2 illustrate vertical striping in a conventional RGB LCD display 

device. 

Figures 3 and 4 illustrate certain font technology terms. 

Figure 5 illustrates processes that may be performed in a font or character 
rendering system in which the present invention may be implemented. 

Figure 6 illustrates processes that may be performed in a graphics display 
interface. 

Figure 7 illustrates processes that may be performed in a line art or graphics 
rendering system in which the present invention may be implemented. 

Figure 8 illustrates processes that may be used to effect various aspects of the 
present invention. 

Figure 9 illustrates an overscaling process operating on character outline 
information. 

Figure 10 is a block diagram of a computer architecture which may be used to 
implement various aspects of the present invention. 

Figure 11 illustrates the operation of an ideal analog to digital sub-pixel 
conversion method. Figure 12 is a high level flow diagram of that method. 

Figure 13 illustrates the operation of a disfavored downsampling method. 
Figure 14 is a high level flow diagram of that method. 
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Figure \ 5 illustrates the operation of a method for deriving sub-pixel element 
information from color scan lines. Figure 16 is a high level flow diagram of that 
method. 

Figure 17 illustrates the operation of an alternative method for deriving sub- 
5 pixel element information from color scan lines. Figure 18 is a high level flow diagram 
of that method. 

Figure 19 illustrates the operation of a method for deriving sub-pixel element 
information from blend coefficient information, as well as foreground and background 
color information. Figure 20 is a high level flow diagram of that method. 
10 Figure 21 illustrates the operation of a method for deriving sub-pixel element 

information from blend coefficient samples, as well as foreground and background 
color information. Figure 22 is a high level flow diagram of that method. 

Figure 23 illustrates the operation of an alternative method for deriving sub- 
pixel element i*ibrmation from blend coefficient samples, as well as foreground and 
1 5 background color information. Figure 24 is a high level flow diagram of that method. 

Figure 25 illustrates the operation of a method for deriving sub-pixel element 
information from blend coefficient samples, as well as foreground and background 
color information, where the foreground and/or background color information may 
vary based on the position of a pixel within the image. Figure 26 is a high level flow 
20 diagram of that method. 

Figure 27 illustrates the operation of an alternative method for deriving sub- 
pixel element information from blend coefficient samples, as well as foreground and 
background color information, where the foreground and/or background color 
information may vary based on the position of a pixel within the image. 
25 Figure 28 is a high level flow diagram of that method. 

Figure 29 is a high level block diagram of a machine which may be used to 
implement various* aspects of the present invention. 

Figure 30 illustrates samples derived from a portion of an overscaled character 

outline. 

30 Figure 31 illustrates the operations of alternative sample combination 

techniques. 
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§4. DETAILED DESCRIPTION 

The present invention concerns novel methods, apparatus and data structures 
for rendering text, line art and graphics on displays having sub-pixel components. The 
following description is presented to enable one skilled in the art to make and use the 
invention, and is provided in the context of particular applications and their 
requirements. Various modifications to the disclosed embodiments will be apparent to 
those skilled in the art, and the general principles set forth below may be applied to 
other embodiments and applications. Thus, the present invention is not intended to be 
limited to the embodiments shown. 

Functions which may be performed by the present invention are introduced in § 
4. 1 below. Then, exemplary environments in which the present invention may operate 
are then described in § 4.2 below. Thereafter, exemplary embodiments, methods, and 
data structures which may be used to effect various aspects of the present invention are 
described in § 4.3 below. Finally, conclusions about the present invention are 
presented in § 4.4 below. 

§ 4.1 FUNCTIONS WHICH MAY BE PERFORMED 

Figure 8 is a high level diagram of processes that may be performed to effect 
various aspects of the present invention, as well as data accepted by or generated by 
such processes. As shown, the processes may act on an analytic image 512/525, such 
as contours, foreground and background colors of a character; an analytic image 
information 702', such as lines, points, contours, foreground and background colors of 
line art; or an image 704' having a higher resolution than that of the display 560 (also 
referred to as an "ultra-resolution image"). Processes associated with rendering a 
character image 512/525 are addressed in § 4.1.1 below. Processes associated with 
rendering a non-character analytic image 702* are addressed in § 4.1.2 below. 
Processes associated with rendering an ultra-resolution image 704' are addressed in § 
4.1.3 below. 

§ 4.1.1 PROCESSES ASSOCIATED WITH RENDERING 
CHARACTER IMAGES 

An ovc-.rscaling or oversampling process 6227710' may accept analytic 
character information, such as contours for example, and a scale factor or grid 820 and 
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overscale and/or oversample the analytic character information. In this context, given 
an analytic character outline arranged on a grid defined by a coordinate system, 
overscaling means stretching the analytic character outline while leaving the coordinate 
system unchanged, while oversampling means compressing the grid defined by the 
5 coordinate system while leaving the analytic character outline unchanged. In the first 
case, in which the analytic character outline is overscaled, an overscaled analytic image 
805 is generated. The overscaled analytic image 805 may then be sampled by sampling 
process 806 to generate ultra-resolution digital image information 810. In the second 
case, in which the analytic character outline (which may have been overscaled) is 

10 oversampled, the ultra-resolution digital image information 810 is generated directly. 
The ultra-resolution image 810 has a higher resolution than the display 560 upon which 
the character is to be rendered. In one example, if the display is a RGB striped LCD 
monitor for example, the ultra-resolution image may have a resolution corresponding 
to the sub-pixel component resolution of the display, or an integer multiple thereof 

15 For example, if a vertically striped RGB LCD monitor is to be used, the ultra- 
resolution image 810 may have a pixel resolution in the Y direction and a 1/3 (or 1/3N, 
where N is an integer) pixel resolution in the X direction. If, on the other hand, a 
horizontally striped RGB LCD monitor is to be used, the ultra-resolution image 810 
may have a pixel resolution in the X direction and a 1/3 (or 1/3N) pixel resolution in 

20 the Y direction. 

The oprional hinting process 626* may apply hinting instructions to the 
overscaled analytic image 805. In one embodiment, the overscaling and/or 
oversampling process 62277 10' overscales the analytic image 515/525 by a factor of an 
arbitrarily large number N (e.g., N = sixteen (16)) in the X direction and does not scale 

25 the analytic image 515/525 in the Y direction. By doing this, in many cases, the hinting 
instructions of the optional hinting process 626' will not cause problems in the X 
direction, which might otherwise occur. In this embodiment, the downscaling process 
807 scales the hinted image by Z/N, where Z is the number of samples per pixel 
element desired (e.g., Z/N = 6/16). The resulting scaled analytic image 808 may then 

30 be sampled by the sampling process 806 to generate the ultra-resolution image 810. 
Consequently, the resulting ultra-resolution digital image information 810 is overscaled 
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by Z (e.g., six (6)) in the X direction. Naturally, in alternative embodiments, the scaled 
analytic image 805 may be directly sampled by the sampling process 806 to generate an 
ultra-resolution image 810. 

Figure 9 illustrates an example of the operation of an exemplary 
5 overscaling/oversampling process 622V7 1 0* used in the case of a vertically striped LCD 
monitor. First, font vector graphics (e.g., the character outline), point size and display 
resolution are accepted. This information is denoted 512/525/910 in Figure 9. The 
font vector graphics (e.g., the character outline) 512/525/910 is rasterized based on the 
point size, display resolution and the overscale factors (or oversample rate). As shown 

1 0 in the example of Figure 9, the Y coordinate values of the character outline (in units of 
font units) are scaled as shown in 920 and rounded to the nearest integer pixel value. 
On the other hand, the X coordinate values of the character outline (in units of font 
units) are overscaled as shown in 930 and rounded to the nearest integer scan 
conversion source sample (e.g., pixel sub-component) value. The resulting data 940 is 

1 5 the character outline in units of pixels in the Y direction and units of scan conversion 
source samples (e.g., pixel sub-components) in the X direction. 

Then, referring back to Figure 8, a process 830 for combining displaced (e.g., 
adjacent, spaced, or overlapping) samples of the ultra-resolution image 624' can be 
used to generate another ultra-resolution image 840 (or an image with sub-pixel 

20 information) which may then be cached into cache storage 880 by the optional caching 
process 870. Each sample of the ultra-resolution image 840 may be based on the same 
number or differing numbers of samples from the ultra-resolution image 810. The 
cached character information 870 may then be accessed by a compositing process 850 
which uses the foreground and background color information 524*. 

25 § 4.1.2 PROCESSES ASSOCIATED WITH PROCESSING NON- 

CHARACTER ANALYTIC IMAGES 
The analytic image 702*, such as a line drawing for example, may be applied to 
the oversampling/overscaling process 6227710' as was the case with the character 
analytic image 512/525. However, since the analytic image 702' may have different 

30 units than that of the character analytic image 512/525, the scale factor 820 applied 
may be different. In any event, the downstream processes may be similarly applied. 
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§4.1.3 PROCESSES ASSOCIATED WITH PROCESSING ULTRA- 
RESOLUTION IMAGES 

Since an ultra resolution image 704' is already "digitized", that is, not merely 
mathematically expressed contours or lines between points, it may be applied directly 
to the process 830 for combining displaced samples of the ultra-resolution image 810 
to generate another ultra-resolution image 840 (or an image with sub-pixel 
information). Downstream processing may then be similarly applied. 

§ 4.1.4 ALTERNATIVE PROCESSING OF ANALYTIC IMAGES 

As shown, the functionality of the overscaling/oversampling process 622V710 1 
and the processes 830 for combining displaced samples may be combined into a single 
step analytic to digital sub-pixel resolution conversion process 860. 

Having introduced processes which may perform functions related to various 
aspects of the present invention, exemplary apparatus, methods and data structures 
which may be used to effect these processes are described in § 4.3 below. First, 
however, an exemplary environment in which the present invention may operate is 
introduced in § 4.2 below. 

§ 4.2 EXEMPLARY ENVIRONMENTS IN WHICH THE INVENTION 
MAY OPERATE 

As alluded to above, the present invention may be used in the context of 
increasing the resolution of text to be rendered on a display, an analytic image, such as 
line art for example, to be rendered on a display, or ultra-resolution graphics to be 
rendered on a display. 

The techniques of the present invention may be applied to a known character 
rendering system such as that illustrated in Figure 6 and described in § 1.2.2.2.1 above. 
The graphics display interface 522 would be modified. More specifically, the scaling 
process 622 and the outline fill process 628 would be replaced with the 
overscaling/oversampling process 622V710', the downscaling process 807, the 
sampling proems 806, and the process 830 for combining displaced samples of the 
present invention, or alternatively, replaced with the analog to digital sub-pixel 
conversion process 860 of the present invention. The techniques of the present 
invention may be similarly applied to a known analytic image rendering system. In 
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some embodiments of the present invention, intermediate results, such as the results 
generated from a first filtering act of a two-part filtering technique, may be generated. 
The second filtering act of the two-part filtering technique may then be performed on 
such intermediate results. The final result of the second filtering act may then be 
5 cached. In such embodiments, the first filtering act of the two-part filtering technique 
may be performed by a font driver, while the second filtering act of the two-part 
filtering technique may then be performed by the graphics display interface (or "GDI") 
of the operating system. 

Finally, techniques of the present invention may be applied to a known graphics 
10 rendered system such as that illustrated in Figure 7 and described in §§ 1.2.3 and 1.2.4 
above. The scaling process 710 would be replaced with a scaling process 6227710' 
and a process 830 for combining displaced samples, or just a process 830 for 
combining displaced samples. 

§4.3 EXEMPLARY EMBODIMENTS, METHODS, AND DATA 
15 STRUCTURES 

Exemplary apparatus in which at least some aspects of the present invention 
may be implemented are disclosed in § 4.3.1 below. Then, exemplary methods for 
effecting processes of the present invention are disclosed in § 43.2. 
§ 4.3.1 EXEMPLARY APPARATUS 
20 Figures 10 and 29 and the following discussion provide a brief, general 

description of an exemplary apparatus in which at least some aspects of the present 
invention may be implemented. Various methods of the present invention will be 
described in the general context of computer-executable instructions, such as program 
modules and/or routines for example, being executed by a computing device such as a 
25 personal computer. Other aspects of the invention will be described in terms of 
physical hardware such as display device components and display screens for example. 

Naturally, the methods of the present invention may be effected by apparatus 
other than those described. Program modules may include routines, programs, objects, 
components, data structures (e.g., look-up tables, etc.) that perform task(s) or 
30 implement particular abstract data types. Moreover, those skilled in the art will 
appreciate that at least some aspects of the present invention may be practiced with 
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other configurations, including hand held devices, multiprocessor systems, 
microprocessor-based or programmable consumer electronics, network computers, 
minicomputers, set top boxes, mainframe computers, displays used in, e.g., 
automotive, aeronautical, industrial applications, and the like. At least some aspects 
5 of the present invention may also be practiced in distributed computing environments 
where tasks are performed by remote processing devices linked through a 
communications network. In a distributed computing environment, program modules 
may be located in local and/or remote memory storage devices. 

Figure 10 is a block diagram of an exemplary apparatus 1000 which may be 

1 0 used to implement at least some aspects of the present invention. A personal computer 
1020 may include a processing unit 1021, a system memory 1022, and a system bus 
1023 that couples various system components including the system memory 1022 to 
the processing unit 1021. The system bus 1023 may be any of several types of bus 
structures including a memory bus or memory controller, a peripheral bus, and a local 

15 bus using any of a variety of bus architectures. The system 1022 memory may include 
read only memory (ROM) 1024 and/or random access memory (RAM) 1025. A basic 
input/output system 1026 (BIOS), including basic routines that help to transfer 
information between elements within the personal computer 1020, such as during start- 
up, may be stored in ROM 1024. The personal computer 1020 may also include a hard 

20 disk drive 1027 for reading from and writing to a hard disk, (not shown), a magnetic 
disk drive 1028 for reading from or writing to a (e.g., removable) magnetic disk 1029 ? 
and an optical disk drive 1030 for reading from or writing to a removable (magneto) 
optical disk 103 * such as a compact disk or other (magneto) optical media. The hard 
disk drive 1027, magnetic disk drive 1028, and (magneto) optical disk drive 1030 may 

25 be coupled with the system bus 1023 by a hard disk drive interface 1032, a magnetic 
disk drive interface 1033, and a (magneto) optical drive interface 1034, respectively. 
The drives and their associated storage media provide nonvolatile storage of machine 
readable instructions, data structures, program modules and other data for the personal 
computer 1020. Although the exemplary environment described herein employs a hard 

30 disk, a removable magnetic disk 1029 and a removable optical disk 103 1, those skilled 
in the art will appreciate that other types of storage media, such as magnetic cassettes, 



WO 00/42762 



PCT/US0O/0OS04 



24 

flash memory cirds, digital video disks, Bernoulli cartridges, random access memories 
(RAMs), read only memories (ROM), and the like, may be used instead of, or in 
addition to, the storage devices introduced above. 

A number of program modules may be stored on the hard disk 1023, magnetic 
5 disk 1029, (magneto) optical disk 1031, RON 1024 or RAM 1025, such as an 
operating system 1035, one or more application programs 1036, other program 
modules 1037, display driver 530/1032, and/or program data 1038 for example. The 
RAM 1025 can also be used for storing data used in rendering images for display as 
will be discussed below. A user may enter commands and information into the 

10 personal computer 1020 through input devices, such as a keyboard 1040 and pointing 
device 1042 for example. Other input devices (not shown) such as a microphone, 
joystick, game pad, satellite dish, scanner, or the like may also be included. These and 
other input devices are often connected to the processing unit 1021 through a serial 
port interface 1046 coupled to the system bus. However, input devices may be 

1 5 connected by other interfaces, such as a parallel port, a game port or a universal serial 
bus (USB). A monitor 560/1047 or other type of display device may also be 
connected to the system bus 1023 via an interface, such as a display adapter 550/1048, 
for example. In addition to the monitor 560/1047, the personal computer 1020 may 
include other peripheral output devices (not shown), such as speakers and printers for 

20 example. 

The personal computer 1020 may operate in a networked environment which 
defines logical connections to one or more remote computers, such as a remote 
computer 1049. The remote computer 1049 may be another personal computer, a 
server, a router, a network PC, a peer device or other common network node, and may 

25 include many or all of the elements described above relative to the personal computer 
1020. The logical connections depicted in Figure 10A include a local area network 
(LAN) 1051 and a wide area network (WAN) 1052 (such as an intranet and the 
Internet for example). 

When used in a LAN, the personal computer 1020 may be connected to the 

30 LAN 1051 through a network interface adapter card (or "NIC") 1053. When used in a 
WAN, such as the Internet, the personal computer 1020 may include a modem 1054 or 
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other means for establishing communications over the wide area network 1052. The 
modem 1054, which may be internal or external, may be connected to the system bus 
1023 via the serial port interface 1046. In a networked environment, at least some of 
the program modules depicted relative to the personal computer 1020 may be stored in 
the remote memory storage device. The network connections shown are exemplary 
and other means of establishing a communications link between the computers may be 
used. 

Figure 29 is a more general machine 2900 which may effect at least some 
aspects of the present invention. The machine 2900 basicaUy includes a processors) 
2902, an input/output interface unit(s) 2904, a storage device(s) 2906, and a system 
bus or network 2908 for facilitating data and control communications among the 
coupled elements. The processor(s) 2902 may execute machine-executable 
instructions to effect one or more aspects of the present invention. At least a portion 
of the machine executable instructions and data structures may be stored (temporarily 
or more permanently) on the storage devices 2906 and/or may be received from an 
external source via an input interface unit 2904. 

Having described exemplary apparatus which may be used to effect at least 
some aspects of the present invention, exemplary methods for effecting at least some 
of the processes discussed in § 4.1 above are described. 

§ 4.3.2 EXEMPLARY METHODS 

In each of the following exemplary methods, a one-part filtering act or a two- 
part filtering act is referenced. An example of applying a one-part filter and a two-part 
filter are described in § 4.3.3 below with reference to Figures 30 and 31. First, 
however, the exemplary methods are described below. 

Figure 1 1 illustrates an operation of an exemplary resolution enhancement 
method 1200 which may be used to effect the analytic to digital sub-pixel conversion 
process 860. Figure 12 is a flow diagram of this method 1200. Referring to both 
Figures 11 and 12, continuous one dimensional RGB functions (or functions of other 
color spaces) 1 1 10 are accepted in act 1210. Eacf3Sft?fiSblor component 
1 1 10 are then sampled (or filtered) as shown in act 1220. As shown by the brackets 
1120 of Figure 11, these filters 1120 may be a three-emitter (where an "emitter" is a 
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sub-pixel component) wide box filter. Notice that the filters 1120 are spatially 
displaced from one another. The spatially displaced filters may be spaced, immediately 
adjacent, or partially overlapping. The output of each of the filters 1 120 is a color 
value 1130 of an emitter. These values 1130 may be gamma corrected (or adjusted) 
5 based on a gamma (or other) response of the display 560 on which the image is to be 
rendered as shown in act 1230. The method 1200 is then left via RETURN node 
1240. 

The me- tod 1200 is ideal in that there are no extra aliasing artifacts introduced. 
However, to effect the filters 1120, an integral over a continuous function 1110 is 
10 evaluated. This integration is possible when the input image 1110 is described 
analytically, but this is not always the case. 

Figure 13 illustrates an operation of a disfavored exemplary resolution 
enhancement method 1400. Figure 14 is a flow diagram of this method 1400. 
Referring to both Figures 13 and 14, a luminance image (Y) 1310 is sampled three (3) 
1 5 times per output pixel (which works out to once per sub-pixel component in a striped 
RGB monitor) as shown in act 1410. This sampling generates three luminance Y 
samples 1320 per pixel. Then, three adjacent samples are box filtered, that is averaged 
together (Note filters 1330 of Figure 13.), to generate red, green and blue sub-pixel 
component values 1340, as shown in act 1420. The method 1400 is then left via 
20 RETURN node 1430. 

Unfortunately, since this method 1400 only samples three (3) times per pixel, it 
produces aliasing artifacts. More specifically, sampling at a particular frequency 
"folds" frequencies above the Nyquist rate down to frequencies below the Nyquist 
rate. In this method 1400, frequencies above 3/2 cycles per pixel are folded down to 
25 frequencies below that rate. In particular, sampling three (3) times per output pixel 
causes input frequencies of two (2) cycles per pixel to be aliased down to one (1) cycle 
per pixel which causes unwanted color fringing. Also, the method 1400 does not 
generalize correctly to full color images since it operates on luminance (rYJonly. 
Further, device response (e.g., gamma) correction is not effected. 
30 Figure 15 illustrates an operation of an exemplary resolution enhancement 

method 1600. This method 1600 may be used to effect the process 830 for combining 
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displaced samples. Figure 16 is a flow diagram of this method 1600. Referring to both 
Figures 15 and 16, the following loop of acts is performed for each color scan line 
1510 as defined by 1610 and 1660. First, discrete values of the color scan line 1510 
are accepted as shown in act 1620. The scanline 1510 of the associated color being 
processed comprises N samples per emitter (which may be 3N per pixel in an RGB 
striped monitor). As shown in Figure 15, the scan lines 1510 contain N=2 samples per 
emitter. Then, the samples 1515 are filtered (e.g., averaged) to generate new samples 
of a three (3) times oversampled color scan line 1520 as shown in act 1640. Then, as 
shown in act 1650, the new samples 1520 are filtered again, for example with box 
filters shown as brackets 1525, to generate color values 1530 associated with sub-pixel 
components. In the illustrated embodiment, the filters (e.g., box filters) 1525 are 
centered at locations that correspond to the centers of the sub-pixel elements. Thus, 
notice that the filters 1525 are offset, and consequently operate at distinct positions 
within the image, for each of the color components as shown. The offset of the filters 
1525 is such that they operate at distinct positions within the image, something 
distinguishes the present invention over standard anti-aliasing techniques. Each of the 
filters 1525 may also have distinct filter weighting coefficients, which further 
distinguishes the present invention over standard anti-aliasing techniques. These acts 
are repeated if there are any further colors to be processed as shown by loop 1610- 
1660. Once all of the colors are processed, the filter output may be gamma corrected 
(or adjusted) based on the gamma (or other) response of the display 560 on which the 
image is to be rendered as shown in act 1670. The process 1600 is left via RETURN 
node 1680. 

As shown in Figure 15, the separate colors may be processed in parallel rather 
than in a sequence of loops as depicted in the method 1600 of Figure 16. 

The number of samples per emitter N may be two (2). This minimizes extra 
aliasing artifacts. As N increases, the computational load for filtering increases. For 
N=2, frequencies that are five (5) cycles per pixel get aliased into one (1) cycle per 
pixel. However, the frequency spectrum of edges tend to go as 1/f, so that using N=2 
sampling should yield about 2.5 times less color fringing due to aliasing than N=l. 
Setting the samples per emitter N to be greater than two (2) yields even less aliasing, 
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but, as stated above, adds computational complexity. Further, the output of the N=2 
filters require less precision to store exactly, and therefore consume less memory and 
may be faster due to decreased memory bandwidth requirements. For example, for a 
patterned display device have three color emitters per pixel, if N>3, more than one byte 
5 per pixel may be needed to store the character information: 

Figure 17 illustrates an operation of an exemplary resolution enhancement 
method 1800. This method 1800 may be used to effect the process 830 for combining 
displaced samples. Figure 18 is a flow diagram of this method 1800. The method 
1800 of Figure 18 is similar to that method 1600 of Figure 16 However, the per- 
10 emitter pre-filtering (1640) and the filtering (1650) are combined into one filter. This 
is possible since both operations are linear. 

Referring now to both Figures 17 and 18, the following loop of acts is 
performed for each color scan line 1710 as defined by acts 1810 and 1840. First 
discrete values of the color scan line 1710 are accepted as shown in act 1820. The 
15 scan line 1710 jf the associated color being processed is then filtered, in one step, to 
generate a color scan line as shown in act 1830. As shown, a filter (e.g., a box filter) 
1720 may be applied to a six-times oversampled (N=2) scanline for each color. The 
filter 1720 may be centered at the sub-pixel element location. Thus, notice that the 
filters 1720 are offset, and consequently operate at distinct positions within the image, 
20 for each of the color components as shown. The offset of the filters 1720 such that 
they operate at distinct positions within the image distinguishes the present invention 
over standard anti-aliasing techniques. Naturally, other filters can be used and other 
values of N can be used. These acts are repeated if there are any further colors to be 
processed as shown by loop 1810-1840. Once all of the colors are processed, the filter 
25 output may be gamma corrected (or adjusted) based on the gamma (or other) response 
of the display 560 on which the image is to be rendered as shown in act 1850. The 
process 1 800 is then left via RETURN node 1 860. 

As shovAl in Figure 17, the separate colors may be processed in parallel rather 
than in a sequence of loops as depicted in the method 1800 of Figure 18. 
30 The methods 1600 and 1800 just described operate on three color channels. 

However, fonts (and line art) are typically not a general RGB image. Rather, fonts 
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(and line art) may be described as a blend (also referred to as "alpha" or a ) between a 
foreground color and a background color. Assume that the blending coefficient at a 
location x is a (x), the foreground color is f and the background color is b. Assume 
further that a filter output is expressed as L[] . Then, the output of a filter of the 
5 present invention applied to a font image may be expressed as: 

L[f«(x) + b(l-«(x))] (2) 
Since L is linear, equation (2) may be expressed as: 

fL[«(x) + b(l-L[«(x)]) (3) 
As these expressions show, only alpha need be filtered. The results of the filtering can 

10 then be used as new blending coefficients between the foreground color and the 
background color. The following methods exploit this observation. 

Figure 19 illustrates an operation of an exemplary resolution enhancement 
method 2000. The method 2000 may be used to effect the process 830 for combining 
displaced samples. Figure 20 is a flow diagram of this method 2000. Referring to both 

15 Figures 19 and 20, an analytic blending coefficient (alpha) 1910 is filtered, using 
displaced filters (See, e.g., three times oversampling filters 1920.), to generate 
oversampled blend coefficient values 1930 as shown in act 2010. Then, as shown by 
loop 2020-2040 for each color, color samples 1940 are determined based on the 
foreground 1932, the background 1934, and the blend coefficient samples 1930. The 

20 output 1940 may then be gamma corrected (or adjusted) 1950 based on the gamma (or 
other) response of the display 560 on which the image is to be rendered as shown in 
act 2050. Although not shown in Figure 19, an inverse display response (e.g., gamma) 
correction may be performed on the foreground 1932 and background 1934 colors 
before the blend operation. The method 2000 is then left via RETURN node 2060. 

25 As can be seen from Figure 19, in one embodiment, there are three (3) alpha 
oversamples 1930 per pixel, one (1) per sub-pixel component. 

As shown in Figure 19, the separate colors may be processed in parallel rather 
than in a sequence of loops as depicted in the method 2000 of Figure 20. 

Figure 21 illustrates an operation of an exemplary resolution enhancement 

30 method 2200. Figure 22 is a flow diagram of this method 2200. The method 2200 
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may be used to effect the process 830 for combining displaced samples. This method 
is somewhat of a hybrid between the method 1600 of Figure 16 and the method 2000 
of Figure 20. Referring to both Figures 21 and 22, oversampled blending coefficient 
(alpha) samples 2110 are accepted as shown in act 2210. These oversampled samples 
5 are then filtered (e.g., averaged) (See bracket 2115.) to generate a new set of blend 
coefficients (alphas) 2120 as shown in act 2220. Then, as shown in act 2230, the new 
set of blend coefficients (alphas) 2120 are filtered again (See, e.g., the filters 2125.) to 
generate a final set of blend coefficients (alphas) 2130. The final set of blend 
coefficients (alsphs) 2130 may be cached. The process then continues as did the 

10 process 2000. More specifically, as shown by loop 2240-2250, for each color, color 
samples 2140 are determined based on the foreground 2132, the background 2134, 
and the final set of blend coefficient samples 2130. The output 2140 may then be 
gamma corrected (or adjusted) 2150 based on the gamma (or other) response of the 
display 560 on which the image is to be rendered as shown in act 2270. Although not 

15 shown in Figure 21, an inverse display response (e.g., gamma) correction may be 
performed on the foreground 2132 and background 2134 colors before the blend 
operation. The method 2200 is then left via RETURN node 2280. As can be seen 
from Figure 21, in one embodiment, there are three (3) alpha oversamples 2130 per 
pixel, one (1) per sub-pixel component. 

20 As shown in Figure 21, the separate colors may be processed in parallel rather 

than in a sequence of loops as depicted in the method 2200 of Figure 22. 

Notice from Figure 21 that the first filtering (e.g., averaging) act 2220 and the 
second filtering act 2230 of the method 2200 effectively generate one (1) final blend 
coefficient (alpha) sample 2130 from six (6) oversampled blend coefficient (alpha) 

25 samples 2110. The method 2400 of Figure 24 combines these two filtering operations 
into a single filtering operation. Figure 23 illustrates an exemplary operation of the 
method 2400 of Figure 24. The method 2400 may be used to effect the process 830 
for combining displaced samples. Referring to both Figures 23 and 24, oversampled 
blending coefficient (alpha) samples 2110 are accepted as shown in act 2410. These 

30 oversampled samples are then filtered (See, e.g., the filters 2320.) to generate a final 
set of blend coefficients (alphas) 2330 as shown in act 2420. The process then 
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continues as d:> 1 the process 2200. More specifically, as shown by loop 2430-2450, 
for each color, color samples 2340 are determined based on the foreground 2132, the 
background 2134, and the final set of blend coefficient samples 2330. The output 
2340 may then be gamma corrected (or adjusted) 2150 based on the gamma (or other) 
response of the display 560 on which the image is to be rendered as shown in act 2460. 
Although not shown in Figure 23 ? an inverse display response (e.g., gamma) correction 
may be performed on the foreground 2132 and background 2134 colors before the 
blend operation. The method 2400 is then left via RETURN node 2470. As can be 
seen from Figure 23, in one embodiment, there are three (3) alpha oversamples 2330 
per pixel, one (1) per sub-pixel component. 

As shown in Figure 23, the separate colors may be processed in parallel rather 
than in a sequence of loops as depicted in the method 2400 of Figure 24. 

In the methods 2200 of Figure 22 and 2400 of Figure 24, it was assumed that 
the blend coefficient (alpha) would be applied to a constant foreground color 2132r, 
2132g, 2132b and a constant background color 2134r, 2134g, 2134b. However, if the 
image, such as a character image, has a shaded background, such as a background 
having a color gradient for example, the blend coefficients (alphas) can be used to 
interpolate between a non-constant foreground and/or background colors. 

The method 2600 of Figure 26 is similar to the method 2200 of Figure 22, but 
permits the foreground and/or background colors to change with position. The 
method 2600 may be used to effect the process 830 for combining displaced samples. 
Figure 25 illustrates an example of the operation of the method 2600 of Figure 26. 
Referring to both Figures 25 and 26, oversampled blending coefficient (alpha) samples 
21 10 are accepted as shown in act 2610. These oversampled samples are then filtered 
(e.g., averaged) (See bracket 2115.) to generate a new set of blend coefficients 
(alphas) 2120 &i shown in act 2620. Then, as shown in act 2630, the new set of blend 
coefficients (alphas) 2120 are filtered (See, e.g., the filters 2125.) to generate a final set 
of blend coefficients (alphas) 2130. This final set of blend coefficients (alphas) 2130 
may then be cached. As shown by nested loops 2640-2680 and 2650-2670, for each 
position and for each color (which may vary with position), color values 2540 
associated with sub-pixel components are determined based on the foreground 2132 at 
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the position, the background 2134 at the position, and the final set of blend coefficient 
samples 2130. In an alternative embodiment, these loops can be re-ordered such that a 
position loop is nested within a color loop. The output 2540 may then be gamma 
corrected (or adjusted) 2550 based on the gamma (or other) response of the display 
5 560 on which the image is to be rendered as shown in act 2690. Although not shown 
in Figure 25, an inverse display response (e.g., gamma) correction may be performed 
on the foreground 2532 and background 2534 colors before the blend operation. The 
method 2600 is then left via RETURN node 2695. As can be seen from Figure 25, in 
one embodiment, there are three (3) alpha oversamples 2130 per pixel, one (1) per 

1 0 sub-pixel component. 

As shown in Figure 25, the separate colors, as well as the separate foreground 
and background colors at separate positions, may be processed in parallel rather than 
in a sequence of loops as depicted in the method 2600 of Figure 26. 

The method 2800 of Figure 28 is similar to the method 2400 of Figure 24, but 

1 5 permits the foreground and/or background colors to change with position. Further, the 
method 2800 of Figure 28 is similar to the method 2600 of Figure 26 but combines the 
separate acts of Altering 2620 and 2630 into a single operation. The method 2800 may 
be used to effect the process 830 for combining displaced samples. Figure 27 
illustrates an example of the operation of the method 2800 of Figure 28. Referring to 

20 both Figures 27 and 28, oversampled blending coefficient (alpha) samples 2110 are 
accepted as shown in act 2810. These oversampled samples are then filtered (See, 
e.g., the filters 2320.) to generate a final set of blend coefficients (alphas) 2330 as 
shown in act 2820. The method 2800 then continues as did the method 2600. More 
specifically, as shown by nested loops 2830-2870 and 2840-2860, for each position 

25 and for each color (which may vaiy with position) color samples 2740 are determined 
based on the foreground 2732 at the position, the background 2734 at the position, 
and the final set of blend coefficient samples 2330. In an alternative embodiment, 
these loops can be reordered such that a position loop is nested within a color loop. 
The output 2740 may then be gamma corrected (or adjusted) 2750 based on the 

30 gamma (or other) response of the display 560 on which the image is to be rendered as 
shown in act 2880. Although not shown in Figure 27, an inverse display response 
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(e.g., gamma) correction may be performed on the foreground 2732 and background 
2734 colors before the blend operation. The method 2800 is then left via RETURN 
node 2890. As can be seen from Figure 27, in one embodiment, there are three (3) 
alpha oversamples 2130 per pixel, one (1) per sub-pixel component. 

As shown in Figure 27, the separate colors may be processed in parallel rather 
than in a sequence of loops as depicted in the method 2800 of Figure 28. 

§ 4.3.3 EXEMPLARY FILTERING METHODS 

Figure ■:;» illustrates a scan line 3010 from a portion of an overscaled character 
940 1 (Recall, Figure 9 in which the letter Q was overscaled in the horizontal direction.). 
In this example, each sample of the scan line 3010 has a value of "0" if its center is 
outside of the character outline 940' and a value of "1" if its center is within the 
character outline 940'. Other ways of determining the value of scanline 3010 samples 
may be used instead. For example, a sample of the scanline 3010 may have a value of 
"1" if it is more than a predetermined percentage (e.g., 50%) within the character 
outline 940', and a value of "0" if it is less than or equal to the predetermined 
percentage within the character outline 940'. These "samples" may correspond to 
alpha values, or color component values. 

Figure 31 illustrates exemplary one-part and two-part filtering techniques 
which may be used to filter samples of a scanline 3010. The exemplary one-part 
filtering technique is illustrated below the scanline 3010 and the exemplary two-part 
filtering technique is illustrated above the scanline 3010. 

In the exemplary one-part filtering technique illustrated below the scanline 
3010, notice that filters, depicted as brackets 3110, operate on six (6) samples of the 
scanline 3010 and are offset by two (2) samples The sums of the samples of the 
scanline 3010 within the filters 3110 are shown in line 3120. In this example, it is 
assumed that the scanline 3010 is derived from a character outline 940' overscaled six 
(6) times in the horizontal (or X) direction. For example, the display on which the 
character is to be rendered may include three (3) sub-pixel elements per pixel, and the 
overscaling factor may be 3N, where N=2. The two (2) sample offset between each of 
the filters 3 1 1 0 may correspond to the N=2 component of the overscaling factor. 
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In the exemplary two-part filtering technique illustrated above the scanline 
3010, notice that each filter of the first set of filters, depicted as brackets 3130, operate 
on two (2) samples of the scanline 3010 and are offset by two (2) samples. The 
averages of the samples of the scanline 3010 within the filters 3130 are shown in line 
5 3140. Notice further that each filter of the second set of filters, depicted as brackets 
3150, operate on three (3) results 3140 generated from the first set of filters 3130 and 
are offset by one (1) result 3 140 (which corresponds to two (2) samples of the scanline 
3010). The average of the results 3140 within each filter 3150 of the second set of 
filters is determined as shown by line 3160. Recall that in this example, it is assumed 
10 that the scanline 3010 is derived from a character outline 940* overscaled six (6) times 
in the horizontal (or X) direction. For example, the display on which the character is 
to be rendered may include three (3) sub-pixel elements per pixel, and the overscaling 
factor may be 3N, where N=2. 

Although the exemplary filters were described as performing averaging or 
15 summing operations, other type of filters may be used. For example, a filter that 
weights certain samples more than others may be used. 
§ 4.4 CONCLUSIONS 

As can be appreciated from the foregoing description, the present invention can 
be used to improve the resolution of analytic image information, such as character 
20 information and line art for example, to be rendered on a patterned display device. 
Further, the present invention can be used to improved the resolution of ultra 
resolution image information, such as graphics for example, to be rendered on a 
patterned display device. 

What is claimed is: 

25 
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1 . For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

a) accepting scan lines of at least two color components, each said 
scan line comprising N samples per sub-pixel element; and 

b) for each of the scan lines of the at least two color components, 

i) filtering the samples to generate new samples, and 

ii) filtering the new samples, at distinct positions, to 
generate values associated with the sub-pixel elements 

2. The method of claim 1 wherein N is two. 

3. The method of claim 1 wherein the act of filtering the new samples 
applies box filters to the new samples, each of the box filters being centered at a spatial 
location corresponding to a sub-pixel element. 

4. The method of claim 1 further comprising an act of gamma correcting 
the new sample : 

5. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

a) accepting scan lines of at least two color components, each said 
scan line comprising at least two samples per sub-pixel element; and 

b) for each of the scan lines of the at least two color components, 
filtering the samples, at distinct positions, to generate values associated with 
the sub-pixel elements. 

6. The method of claim 5 wherein the act of combining the samples applies 
a box filter to the samples. 

7. The method of claim 5 further comprising an act of gamma correcting 
the new samples. 

8. Jot use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

a) accepting a blend coefficient analytic scan line; 
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b) filtering and sampling the blend coefficient analytic scan line to 
generate blend coefficient samples; and 

c) applying a foreground and background color value to each of 
the blend coefficient samples to generate values associated with the sub-pixel 

5 elements, 

wherein there are M sub-pixel elements per pixel, where M is an 
integer greater than one, 

wherein each of the M sub-pixel elements per pixel corresponds 
to a single color component, and 
1 o wherein the act of applying a foreground and background color 

value to each of the blend coefficient samples includes, for each of the 
single color components, applying a foreground and background color 
component value to an associated blend coefficient sample to generate a 
value corresponding to the single color component. 
15 9. The method of claim 8 further comprising an act of gamma correcting 

the values. 

10. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

20 a) accepting a scan line having blend coefficient samples, said scan 

line comprising N samples per sub-pixel element; 

b) filtering the samples to generate new samples; 

c) filtering the new samples to generate filtered samples; and 

d) applying a foreground and background color value to each of 
25 the filtered samples to generate color values associated with the sub-pixel 

elements, . 

wherein there are M sub-pixel elements per pixel, where M is an 
integer greater than one, 

wherein each of the M sub-pixel elements per pixel corresponds 
30 to a single color component, and 
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wherein the act of applying a foreground and background color 
value to each of the filtered samples to generate color values includes, 
for each of the single color components, applying a foreground and 
background color component value to an associated filtered sample to 
generate a color value corresponding to the single color component. 

1 1 . The method of claim 10 wherein N is two. 

12. The method of claim 10 wherein the act of filtering the new samples 
applies a box filter to the new samples. 

13. The method of claim 10 further comprising an act of gamma correcting 
the color values. 

14. The method of claim 10 wherein at least one of the foreground and 
background color values may change as a function of a position of the image. 

15. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

a) accepting a scan line having blend coefficient samples; 

b) combining the samples to generate new samples; and 

c) applying a foreground and background color value to each of 
the new samples to generate color values associated with the sub-pixel 
elements, 

wherein there are M sub-pixel elements per pixel, 
where M is an integer greater than one, 

wherein each of the M sub-pixel elements per pixel corresponds 
to a single color component, and 

wherein the act of applying a foreground and background color 
value to each of the new samples to generate color values includes, for 
each of the single color components, applying a foreground and 
background color component value to an associated new sample to 
generate a color value corresponding to the single color component. 

16. The method of claim 15 wherein the act of combining the samples 
applies a box filter to the samples. 



WO 00/42762 



PCT/US00/0O804 



38 

17. The method of claim 15 further comprising an act of gamma correcting 
the color values. 

18. The method of claim 15 wherein at least one of the foreground and 
background color value may change as a function of a position of the image. 

5 19. For use in a system for rendering an image on a device having a number 

of sub-pixel elements per pixel, a method for processing image information, the 
method comprising: 

a) accepting continuous one-dimensional color functions; and 

b) filtering each of the continuous one-dimensional color functions 
10 at distinct positions to generate values associated with each of the number of 

sub-pixel elements. 

20. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, apparatus for processing image information, the 
apparatus comprising: 

15 a) means for accepting scan lines of at least two color components, 

each said scan line comprising N samples per sub-pixel element; 

b) means, for each of the scan lines of the at least two color 
components, for filtering the samples to generate new samples; and 

c) means, for each of the at least two color components, for 
20 filtering the new samples at distinct positions. 

2 1 . The apparatus of claim 20 wherein N is two. 

22. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, apparatus for processing image information, the 
apparatus comprising: 

25 a) means for accepting scan lines of at least two color components, 

each said scan line comprising at least two samples per sub-pixel element; and 

b) means, for each of the at least two color components, for 
combining the samples at distinct positions to generate values associated with 
the sub-pixel elements. 
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23. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel, apparatus for processing image information, the 
apparatus comprising: 

-.0 means for accepting a blend coefficient analytic scan line; 
5 b) a sampler for filtering and sampling the blend coefficient analytic 

scan line to generate blend coefficient samples; and 

c) means for applying a foreground and background color value to 
each of the blend coefficient samples to generate values associated with the 
sub-pixel elements, 

1 0 wherein there are M sub-pixel elements per pixel, where N is an 

integer greater than one, 

wherein each of the M sub-pixel elements per pixel corresponds 
to a single color component, and 

wherein for each of the single color components, the means for 
1 5 applying apply a foreground and background color component value to 

an associated blend coefficient sample to generate a value 
corresponding to the single color component. 

24. For use in a system for rendering, an image on a device having a 
number of sub-pixel elements per pixel, apparatus for processing image information, 

20 the apparatus comprising: 

a) means for accepting a scan line having blend coefficient samples, 
said scan line having N samples per sub-pixel element; 

b) means for filtering the samples to generate new samples; 

c) a filter for filtering the new samples to generate filtered samples; 

25 and 

d) means for applying a foreground and background color value to 
each of the filtered samples to generate values associated with the sub-pixel 
elements, 

wherein there are M sub-pixel elements per pixel, where M is an 
30 integer greater than one, 
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wherein each of the M sub-pixel elements per pixel corresponds 
to a single color component, and 

wherein, for each of the single color components, the means for 
applying apply a foreground and background color component value to 
5 an associated filtered sample to generate a color value corresponding to 

the single color component. 

25. The apparatus of claim 24 wherein N is two. 

26. The method of claim 24 wherein at least one of the foreground and 
background color value may change as a function of a position of the image. 

10 27. For use in a system for rendering an image on a device having a number 

of sub-pixel elements per pixel, apparatus for processing image information, the 
apparatus comprising: 

a) means for accepting a scan line having blend coefficient samples; 

b) means for combining the samples to generate new samples; and 

1 5 c) means for applying a foreground and background color value to 

each of the new samples to generate color values associated with the sub-pixel 
elements, 

wherein there are M sub-pixel elements per pixel where M is an 
integer greater than one, 
20 wherein each of the M sub-pixel elements per pixel corresponds 

to a single color component, and 

wherein, for each of the single color components, the means for 
applying apply a foreground and background color component value to 
an associated new sample to generate a color value corresponding to 
25 the single color component. 

28. The apparatus of claim 27 wherein at least one of the foreground and 
background color value may change as a function of a position of the image. 

29. For use in a system for rendering an image on a device having a number 
of sub-pixel elements per pixel apparatus for processing image information, the 

30 apparatus comprising: 
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a) means for accepting continuous one-dimensional color 
functions; and 

b) means for filtering each of the continuous one-dimensional color 
functions at a distinct position to generate values associated with each of the 
number of sub-pixel elements. 

30. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 1. 

31. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 2. 

32. A machine readable medium having stored instructions which, when 
executed by a machine used in an system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 5. 

33. A machine readable medium having stored instructions which, when 
executed by a machine used in an system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 8. 

34. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 10. 

35. A machine readable medium having stored instructions which, when 
executed by a machine used in a system -for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 1 1 . 

36. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 14. 

37. A machine readable medium having stored instructions which, when 
executed by a machine used in an system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 15. 
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38. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 16. 

39. A machine readable medium having stored instructions which, when 
executed by a machine used in a system for rendering an image on a device having a 
number of sub-pixel elements per pixel, performs the method of claim 19. 
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